apiVersion: tekton.dev/v1beta1
kind: Task
metadata:
  name: cluster-var-update
  namespace: ecs-assisted-installer-pipeline
spec:
  params:
    - name: cluster-name
      description: "name of the cluster to be deployed"
      type: string
    - name: infra-env
      description: "name of the infra-env"
      type: string
      default: acm-config
    - name: rack-ns
      description: "namespace of rackvars"
      type: string
    - name: ocp-neptune-artifacts-repo
      description: "Provide ocp_neptune_racks for infra-env pipeline and ocp_neptune_clusters for cluster pipeline"
      type: string
    - name: datacenter
      description: "datacenter value for cluster"
      type: string

  steps:
    - name: cluster-var-update
      image: python:3.8-slim
      script: |
        #!/usr/bin/env python
        import os
        import subprocess
        import json
        import yaml

        # Initialize variables from environment
        rack_name = os.environ['infra_env']  # This is the rack name
        rack_ns = os.environ['rack_ns']  # This is the namespace for the rack

        # Path to the cluster_vars.yaml file
        output_path = f"/workspace/output/{os.environ['datacenter']}/{rack_name}/cluster_vars.yaml"

        # Function to fetch BMC IPs and machine names for a specific rack from the ACM hub
        def fetch_bmc_ip_and_names(rack_name, rack_ns):
            # Fetch the machine names and BMC IPs from the specified rack resource
            result = subprocess.run(['oc', 'get', 'rack', rack_name, '-n', rack_ns, '-o', 'json'], stdout=subprocess.PIPE)
            rack = json.loads(result.stdout)

            machine_names = []
            bmc_ips = []

            # Extract machine names and BMC IPs from the rack data
            for machine in rack['spec']['machines']:
                machine_names.append(machine['name'])
                bmc_ips.append(machine['bmc_ip'])

            return machine_names, bmc_ips

        # Load existing cluster_vars.yaml if it exists
        if os.path.exists(output_path):
            with open(output_path, 'r') as file:
                existing_data = yaml.safe_load(file)
        else:
            existing_data = {}

        # Fetch Machine Names and BMC IPs for the specified rack
        machine_names, bmc_ips = fetch_bmc_ip_and_names(rack_name, rack_ns)

        # Combine BMC IPs in a dictionary format for YAML
        masters = []
        workers = []

        # Assuming first three are masters and the rest are workers (adjust as necessary)
        for i in range(3):
            masters.append({
                'name': machine_names[i],
                'bmc_ip': bmc_ips[i]
            })

        for i in range(3, len(machine_names)):
            workers.append({
                'name': machine_names[i],
                'bmc_ip': bmc_ips[i]
            })

        # New rack data to be merged into existing data
        new_rack_data = {
            'rack': {
                1: {  # Adding the "1:" key
                    'subnet': '10.226.92.0',  # Replace with the actual subnet if different
                    'machines': {
                        'masters': masters,    # Masters list
                        'workers': workers     # Workers list
                    }
                }
            }
        }

        # Merge the new rack data into the existing data
        existing_data.update(new_rack_data)

        # Write the updated data back to cluster_vars.yaml
        with open(output_path, 'w') as file:
            yaml.dump(existing_data, file, default_flow_style=False)

        print(f"Rack information for {rack_name} has been added to {output_path}")

      env:
        - name: infra_env
          value: "$(params.infra-env)"
        - name: rack_ns
          value: "$(params.rack-ns)"
        - name: datacenter
          value: "$(params.datacenter)"
